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(57) Abstract: Internet Relay Chat is provided for mobile devices (e.g., mobile telephones) using an IRC proxy approach. The 
mobile chat proxy server (1 00) facilitates 2- way text conversations between users of cell phones, web browser users, and/or other 
chat group users, e.g., Instant Messaging service users. In the IRC proxy approach, SMPP and/or Intcrworking Function (IWF) 
interfaces are used to provide Internet Relay Chat functionality to mobile handsets (102).IRC proxy is provided by a mobile chat 
proxy server (100) T also referred to as a "mobile originated chat server" or "chat server", and/or under its trademark name of a 
"MOChat proxy server". The mobile chat proxy server (100) exchanges message objects with a wireless Internet gateway. The 
mobile chat proxy server (100) uses standard IRC protocol in communications with the standard or conventional IRC server (190) 
supporting the relevant chat group. The mobile chat proxy server (100) maintains a real-time proxy connection to the conventional 
IRC server for each mobile device. In operation T the mobile chat proxy server (100) interprets chat messages from mobile devices, 
and determines if and how they should be forwarded to the conventional IRC server (190). The mobile chat proxy server (100) 
utilizes an RMI interface between the mobile chat proxy server (100) and the wireless Internet gateway for sending messages to chat 
group participants using mobile handsets (102). 
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BACKGROUND OF THE INVENTION 

1. Field of the Invention 

5 The present invention relates generally to wireless 

telecommunication, Instant Messaging, and Internet chat applications and 
systems. 

2. Background of Related Art 

io Internet Relay Chat (IRC), ICQ, and Instant Messaging are digital 

techniques allowing users of computers to communicate textual messages to one 
another in a real-time environment. 

IRC ("Internet Relay Chat") is a system for chatting that involves a 
set of rules and conventions and client/server software. Unlike older chat 

1 5 systems, IRC is not limited to just two participants. Conventionally, an IRC client 
can be downloaded to a user's computer (e.g., PC or Palm Pilot™). 

IRC is based on a client-server model, or network, as shown in Fig. 
18. A user must connect to an IRC server in an IRC network to start or join an 
IRC chat group. As shown in Fig. 18, an IRC network is a collection of servers 

20 linked together. When you log onto an IRC network, you are connecting to one of 
the servers on that network. All servers on the IRC network share and have 
access to the same information. Thus, each server knows who is on the network, 
which chat rooms the users are currently in, and which servers the users are 
using as well. 

25 Using IRC, a new chat group can be started, or an existing chat 

group can be joined. There is a protocol for discovering existing chat groups and 
their members. Perhaps the most common IRC networks are IRCnet (mostly 
European), Efnet (mostly North American), Undernet, and Dalnet. Popular IRC 
clients include mIRC for Windows, IRCIe for MacOS, and irc2 (the original client) 

30 for UNIX-based operating systems. 

The IRC protocol uses Transmission Control Protocol (TCP). TCP is 
a connection-oriented protocol used along with the Internet Protocol (IP) to send 
data in the form of message units between computers over the Internet. While IP 
takes care of handling the actual delivery of the data, TCP takes care of keeping 
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track of the individual units of data (called packets) that a message is divided into 

for efficient routing through the Internet. 

ICQ ("I Seek You") is a program you can download that will let you 

know when friends and contacts are also online on the Internet, page them, and 
5 chat with them. In order to get maximum benefit from ICQ, both parties must have 

downloaded the ICQ program and have received a user identification number 

(UIN). The download and registration procedure are simple and enable you to 

send messages, files (single, multiple or whole directories), and URLs directly to 

your friends 1 desktops. In addition, you can initiate an IRC-style chat session or 
io voice and video-voice connection and play games with other ICQ members that 

you are in touch with. Your contact is signaled of an incoming event as soon as it 

arrives and has immediate access to it. 

Instant Messaging is a type of communications service that enables 

you to create a private chat room with another individual. Typically, an instant 
15 messaging system alerts you whenever somebody on your private list is online. 

You can then initiate a chat session with that particular individual. 

Currently, there are several competing instant messaging systems, 

and no standard. Therefore, anyone a computer user would want to send an 

instant message to must use the same instant messaging system that the sender 
20 uses. 

Conventionally, IRC, ICQ, and Instant Messaging are generally 
limited for use by users having a personal computer (PC) attached to the Internet. 

More recently, there have been general announcements by some 
manufacturers of plans to develop Instant Messaging for use in a mobile handset. 

25 However, the proposed solutions apparently utilize new, vendor-specific handsets 
(e.g., from MOTOROLA) and a proprietary chat protocol (e.g., AOL's Instant 
Messenger). Thus, a user desiring to utilize such a new service must by a new 
mobile handset from the particular vendor including functionality to operate the 
necessary proprietary chat protocol. 

30 There have also been announcements of plans to develop browser- 

specific software for chat. However, such solutions require a mobile handset 
manufacturer to load special software on the handsets, which is not a procedure 
that can be performed easily or properly by many consumers or carriers. 

Conventional approaches or plans allowing implementation of 

35 Instant Messaging or other chat functionality in mobile handsets (e.g., wireless 
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telephones using analog, TDMA or CDMA RF technology) do not provide for chat 
participation by older, currently existing mobile telephones (i.e., "mobile 
terminated telephones"). Moreover, the conventional approaches do not allow 
standard mobile telephones (i.e., not having browser-specific chat software or 
5 other proprietary software loaded) to originate a chat message. 

There is a need for a technique and apparatus which allows 
standard mobile telephones to participate in Internet chat groups such as those 
provided by Instant Messaging, Internet Relay Chat (IRC), or ICQ. 

10 SUMMARY OF THE INVENTION 

In accordance with the principles of the present invention, a device 
and method for providing access to a channel of an Internet Relay Chat group to a 
mobile device comprises placing a mobile chat proxy server in a communication 
path between a standard Internet Relay Chat server and a wireless gateway 

15 server supporting the mobile device. The mobile chat proxy server forwards chat 
commands from the mobile device to the standard Internet Relay Chat server. 

Another device and method of handling chat group commands 
between a mobile device and a chat group server in accordance with another 
aspect of the present invention comprises examining non-standard chat group 

20 commands transmitted by a mobile device. The standard chat group commands 
are forwarded based on the non-standard chat group commands to the chat group 
server. 

BRIEF DESCRIPTION OF THE DRAWINGS 

25 Features and advantages of the present invention will become apparent to those 
skilled in the art from the following description with reference to the drawings, in 
which: 

Fig. 1 shows an exemplary chat system using a proxy chat server 
between a standard IRC server and a service provider gateway such as a wireless 
30 internet gateway, in accordance with the principles of the present invention. 

Fig. 2 shows exemplary types of interfaces used to interconnect the 
various devices shown in Fig. 1 . 

Fig. 3 shows how the invention is able to support various types of 
clients for Chat services. The software allows other applications, such as web 
35 servers and WAP Servers, to enroll participants in Chat groups. 
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Fig. 4 shows an overview of the communications between the user 
of the mobile device, the short messaging system controller the mobile chat proxy 
server, the database, the conventional IRC server, and IRC clients participating in 
a chat group, in accordance with the principles of the present invention. 
5 FiQ- 5 shows an exemplary top level sequence of events in an initial 

mobile originated connection using a mobile chat proxy server, in accordance with 
the principles of the present invention. 

Fig. 6 shows an exemplary top level sequence of events in a mobile 
originated conversation using a mobile chat proxy server, in accordance with the 
io principles of the present invention. 

Fig. 7 shows an exemplary top level sequence of events for an 
improperly formatted mobile originated message using a mobile chat proxy server, 
in accordance with the principles of the present invention. 

Fig. 8 shows an exemplary processing of a message queue of a 
is mobile chat proxy server, in accordance with the principles of the present 
invention. 

Fig. 9 shows an exemplary sequence of events in an Applet-based 
conversation, in accordance with the principles of the present invention. 

Fig. 10 illustrates the components of an IRC chat group solution 
20 allowing IRC-enabled mobile handsets to participate in IRC chat groups using an 
Interworking Function (IWF) connection (in place of the SMPP connection shown 
in Fig. 1 ), in accordance with the principles of the present invention. 

Fig. 1 1 shows an initial connection to the IRC server shown in Fig. 
1 0, in accordance with the principles of the present invention. 
25 Fi 9. 12 is a detailed process flow showing the validation of the 

mobile user in the mobile chat system shown in Fig. 1 1 . 

Fig. 13 shows an update of the provisioning database in the system 
of Fig. 1 0, in accordance with the principles of the present invention. 

Fig. 14 shows an exemplary process of an IRC "Notice" command, 
30 in accordance with the principles of the present invention. 

Fig. 15 shows an exemplary IRC "Notify" command having special 
properties for an SMS, in accordance with the principles of the present invention. 

Fig. 16 shows a special "Ghost" command to enable a user to 
monitor an IRC chat group (or channel) via the short message service (SMS) 
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without maintaining a connection to the conventional IRC server, in accordance 
with the principles of the present invention. 

Fig. 17 shows the implementation of a special IRC "Invite" command 
to provide the mobile user with the opportunity to use SMS to extend chat 
s invitations to other mobile users, in accordance with the principles of the present 
invention. 

Fig, 18 shows a conventional Internet Relay Chat (IRC) group based 
on a client-server model, or network, wherein a user connects to an IRC server in 
an IRC network to start or join an IRC chat group (channel). 

]<) 

DETAILED DESCRIPTION OF PREFERRED EMBODIMENTS 

The present invention allows mobile and other devices to participate 
in Internet Relay Chat (IRC) groups, ICQ, and/or Instant Messenger groups using 
open standards (e.g., IRC). The solution allows standard mobile originated, WAP, 

I5 and HDML handsets to both read (e.g., "lurk") and to participate in chat groups, 
and allows standard mobile terminated handsets and pagers to read (i.e., "lurk") in 
chat groups. It also allows a user to distribute a Chat session across two mobile 
devices: one for posting messages (e.g. a Palm VII) and one for receiving 
messages (e.g., a mobile-terminated phone). 

20 Fig. 1 shows an exemplary chat system using a proxy chat server 

100 between a standard IRC server 190 and a service provider gateway such as a 
wireless internet gateway 106, in accordance with the principles of the present 
invention. 

In particular, Fig. 1 shows an architecture using a 'best of breed' 
25 component-based approach, utilizing a third party standard IRC server 190, a 
wireless Internet gateway 106, and an (optional) Oracle database 108. 

An appropriate wireless Internet gateway 106 is commercially 
available from Telecommunication Systems, Inc. in Annapolis, Maryland. The 
wireless internet gateway 106 is accessed by a subscriber mobile handset 102 
30 through a servicing short message servicing center (SMSC) 104. 

Importantly, as shown in Fig. 1, a mobile chat (MOChat™) proxy 
server 100 is provided between the standard IRC server 190 and the relevant 
wireless internet gateway 106. The mobile chat proxy server 100 is also referred 
to as a "mobile originated chat server", and/or under its trademark name of a 
35 "MOChat™ proxy server". The mobile chat proxy server 100 integrates the 
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components shown in Fig. 1 by serving as a proxy between the wireless Internet 
gateway 106 and the siandard IRC server 190. 

Fig. 2 shows exemplary types of interfaces used to interconnect the 
various devices shown in Fig. 1. 
s In particular, Fig. 2 shows the insertion of a mobile chat proxy server 

100 between a conventional IRC server 190a and a wireless Internet gateway 
106. Thus, the solution utilizes a two-tiered IRC server approach-one 
conventional (IRC server 190a), and an inventive proxy server (MO Chat™ server 
100), to allow wireless device (e.g., mobile handset 102) users to read and/or 
io participate in chat groups. Note the presence of the Internet 202 and wireless 
network 204. 

In Fig. 2, all IRC communications are according to IRC request for 
comments (RFC) 1459. Moreover, as shown, all SMPP communications are 
according to the v3.3 specification published by Aldiscon. SMPP v3.4 can also be 
is supported. 

Communication between the mobile chat proxy server 100 and the 
wireless Internet gateway 106 uses the Java Remote Invocation Protocol (RMI). 
RMI is a distributed computing protocol that allows separate programs, potentially 
on separate computers, to exchange software objects. Using a special 
20 implementation of this protocol, a very powerful and flexible mechanism is 
provided for external applications (such as the mobile chat proxy server 100) to 
interact in an object-oriented fashion with the SMSC 104 and wireless handsets 
102. 

Any conventional IRC server can be used as the standard IRC 
25 server 190a shown in the Figs. 1 and 2. Although some IRC servers can be 
modified for special needs, a strength of the principles of the present invention is 
that the use of the mobile chat proxy server 100 allows chat room participation to 
conform to open standards. Exemplary RFC and IRC architecture can be found at 
http://www.ietf.org/rfc/rfc1 459.txt. 
30 After binding to the wireless Internet gateway 106, the mobile chat 

proxy server 100 exchanges message objects with the wireless Internet gateway 
106. The messages are of various types, including text messages to and from 
wireless devices such as the wireless mobile handset 102 shown in Fig. 2. By 
binding to the wireless Internet gateway 106, the mobile chat proxy server 100 
35 can receive messages from mobile (i.e., wireless) devices, and/or send messages 
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to other mobile (i.e., wireless) devices, providing the basis for chat group 
participation by mobile devices. 

The interface to the conventional IRC server 190a from the mobile 
chat proxy server 100 uses standard IRC protocol. Thus, the present invention 
5 allows the continued use of existing IRC servers 190a, with the added functionality 
of allowing mobile users to participate in chat groups by simply adding a mobile 
chat proxy server 100 as an interface device to a wireless network. 

The mobile chat proxy server 100 maintains a real-time proxy 
connection to the conventional IRC server 190a for each mobile device, e.g., 
io mobile handset 102. From the perspective of the IRC server 190a, connections 
through the mobile chat proxy server 100 appear as regular (e.g., standard 
conforming) IRC clients. Accordingly, chat messages from the conventional IRC 
server 190a are sent to a connection in the mobile chat proxy server 100, which 
are in turn forwarded through the wireless Internet gateway 106 to the mobile 
l5 devices, e.g., mobile handset 102. 

In operation, the mobile chat proxy server 100 interprets chat 
messages from mobile devices, and determines if and how they should be 
forwarded to the conventional IRC server 190a. 

For example, a message with content "#ABC" will cause the mobile 
20 chat proxy server 100 to send a command to the conventional IRC server 190a 
that will enroll the relevant device in the #ABC chat group. At that point, the 
relevant mobile user will be participating in the #ABC chat group, and all other 
group members, Internet based or otherwise, will be aware of the new participant. 

Once registered in a chat group, any non-command based 
25 messages from a mobile device will be directly forwarded by the mobile chat proxy 
server 100 to the conventional IRC server 190a, where they will be broadcast to 
all chat group members. Messages from other members of the chat group will be 
sent from the conventional IRC server 190a to a connection in the mobile chat 
proxy server 100, then to the wireless Internet gateway 106, and then finally to the 
30 mobile handset 102. 

The interface between the mobile chat proxy server 100 and the 
wireless Internet gateway ("gateway") 106 is unique in that the gateway acts as 
wireless messaging middleware in which the details of reliable transmission to the 
wireless destination (e.g., mobile handset 102) are hidden from the chat group 
35 clients. 
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In particular, using Java's RMI protocol between the mobile chat 
proxy server 100 and tne wireless Internet gateway 106, mobile chat group clients 
can directly access the Queue and SMPP objects within the wireless Internet 
gateway 106. Most simply, mobile chat group clients can create a message 

5 object and insert it into a remote queue of the wireless Internet gateway 106. 
Upon doing so, the wireless Internet gateway 106 will synchronously return a 
unique message tracking number. The remote queue can later be queried to 
determine the status of delivery. 

In this exemplary scenario, details regarding message delivery can 

io be completely hidden from the mobile chat group client; whether it is delivered by 
SMPP. TNPP, or the Web does not matter. The mobile chat proxy server 100 
utilizes the RMI interface between the mobile chat proxy server 100 and the 
wireless Internet gateway 106 for sending messages to the chat group 
participants using mobile handsets. 

l5 The mobile chat proxy server 100 also utilizes the remote SMPP 

interface of the wireless Internet gateway 106, which communicates with the short 
messaging system controller (SMSC) 104. A suitable SMSC is commercially 
available from Telecommunication Systems Inc. in Annapolis, Maryland. 

The remote SMPP interface allows mobile chat group clients to 

20 directly interact with the SMPP messaging traffic of the SMSC 104, and thus 
allows a mobile chat group client to send and receive SMPP message objects of 
various types. In the disclosed embodiment, the SMPP message types are 
object-oriented- 

In the disclosed embodiment, an object or module named 
25 "MobileReceiver" binds to the SMPP interface of the wireless Internet gateway 
106 to allow reception of mobile chat group messages. Similarly, an object or 
module named "MobileSender" utilizes the remote queue to allow delivery of chat 
group messages to wireless devices (e.g., mobile handsets) serviced by the 
wireless network 204. 

30 The mobile chat proxy server 100 is able to receive SMPP 

messages through the remote SMPP interface from the wireless Internet gateway 
106 that represent mobile originated messages from the mobile device (e.g., 
mobile handset 102). The mobile chat proxy server 100 is therefore able to 
receive chat group messages from the mobile handset 102, interpret them in the 
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IRC context, and send appropriate standardized IRC commands to the 
conventional IRC server 190a. 

This solution has applicability beyond regular chat groups. For 
instance, to subscribe to various pre-defined chat groups (i.e. T Information Cafe™ 
5 chat groups), only a predefined application in the mobile chat proxy server 100 
may publish messages to these chat groups. Information Cafe™ chat groups can 
be created according to the type of information that will be published by the 
predefined application. For example, Information Cafe™ chat groups might exist 
for hourly news updates. 

io Use of an IRC proxy gateway in accordance with the principles of 

the present invention provides front-end services to a standard IRC server. For 
example, the IRC proxy gateway (i.e., mobile chat proxy server 100) can provide 
user validation, special short messaging system (SMS) handling for certain 
commands (e.g., Notify, Notice, Mode, Ghost, etc.), and/or customer-requested 

!5 metrics. Moreover, a mobile chat proxy server 100 provides mobile 
enhancements to standard IRC commands. The mobile chat proxy server 100 
can utilize any appropriate operating system, e.g., UNIX or WINDOWS NT. 

A core notion of the present invention is the placement of a proxy 
between an otherwise conventional Internet Relay Chat (IRC) server and the 

20 wireless components of a mobile system. Moreover, features such as summoning 
other mobile users to join a mobile originated chat group, and/or ghosting a chat 
session remain the same. 

Figure 3 shows how the Chat Server integrates with other Server 
Software to provide Chatting capabilities to a greater number of mobile devices, 

25 including PALM VII and phone browser clients. The Chat Server offers an open 
software interface based on the Remote Method invocation protocol. Using this 
interface, TCS has enabled Palm VII, WML, and HDML handset browsers to 
interact with the Chat Server. These three devices interact with the Chat Server 
by way of a Web Server with Java Servlet support. The phone browsers must 

30 also communicate through an Unwired Planet Server or WAP Server for HDML 
and WML browsers, respectively. The devices interact with a Servlet running on 
the Web Server. Using the Chat Server's RMI connection, the Servlet is able to 
pass chat messages between the Chat Server and the browser device. The result 
is that all of these devices can participate in the same chat groups and can have 

35 awareness of one another. 
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Figure 3 also illustrates how standard IRC enabled clients can 
interact directly with the Chat Server. The Chat Server is thereby able to provide 
consistent user authentication and special services to the IRC clients. IRC clients 
are available for most major computer systems as well as small devices such as 
Palm Pilots and Windows CE devices. It is also also possible to run IRC client 
software natively on mobile phones. In which case, as a standard IRC client, the 
phone directly interacts with the Chat Server. Figure 11 illustrates this scenario, 
which is described in greater detail later in this document. 

Finally, Figure 3 also shows integration between the Chat Server 
and external Chat Services such as AOL's Instant Messenger (AIM) and ICQ. 
The Chat Server is designed to accommodate gateway services that translate 
between these proprietary systems and IRC. Since the Chat Server is the central 
messaging hub, multiple devices from multiple services can all intercommunicate 
and be aware of one another. 

When integrating with Mobile Originated handsets through the 
Wireless Internet Gateway and SMSC, users may issue special chat commands. 
In accordance with the principles of the present invention, rather than requiring 
upgrading of an existing IRC server base, a mobile chat proxy server 100 can be 
interjected between the participating client and the relevant conventional IRC 
server 190. In this way, the mobile chat proxy server 100 intercepts the special 
commands, interprets the special commands, and either acts on the special 
commands or forwards the special commands to the conventional IRC server 190. 

For example, a chat group user may issue the command 
"alias*Fred". This special command will be intercepted by the mobile chat proxy 
server 100 T and interpreted to cause the mobile chat proxy server 100 to send an 
appropriate command to the conventional IRC server 190 to change the alias for 
the relevant mobile user to 'Fred 1 . 

As another example, the "summon" command may be used to allow 
mobile users to request other mobile users to join a particular chat group. The 
"summon" command is processed by the mobile chat proxy server 100 and acted 
on itself, without forwarding the same to the standard IRC server 190. 

The specifics of the actual command strings to be entered for 
interpretation by the mobile chat proxy server 100 (e.g., 'alias', 'summon', etc.) 
may be configured by the administrator. 
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System requirements and analysis of the exemplary mobile chat 
proxy server 100 follow, together with a more detailed description of the 
relationship between the mobile chat proxy server 100 and the conventional IRC 
Server 190. 

5 The mobile chat proxy server 100 facilitates 2-way text 

conversations between users of cell phones 102, web browser users 330, and/or 
other chat group users, e.g., Instant Messaging service users. 

Several possible scenarios are accommodated by the mobile chat 
proxy server 100, in accordance with the principles of the present invention. 

to 

Scenario A: Peer to Peer user chats 

1 . Mobile (i.e., wireless) user A @MIN (4102631 111) would like to send 
an individual message to another member in the Chat community. 

2. Using her phone, mobile user A sends a mobile originated message 
, 5 to '3428' (CHAT) with body "@<alias> <message_content>. w 

3. The content is sent to the IRC Server as a private message, where it 
is delivered only to the specified recipient. If the recipient happened 
to be a mobile user, then the message would arrive on the 
recipient's mobile device. 

20 

Scenario B: Mobile user creates/initiates participation in chat group 

1 . Mobile user A would like to participate in a chat group (#LB). They 
enter the command "#LB W to destination CHAT. 

2. The SMSC 104 forwards the message to the mobile chat proxy 
25 server 100 for handling. If the group #LB was already created, then 

the mobile chat proxy server 100 adds mobile user A to the chat 
group and forwards messages sent to that chat group their way. If 
that chat group is not yet created, then that chat group is 
automatically created and they are added. 

30 

Scenario C: Web browser user joins chat group and requests mobile user's 
participation. 

1 . Web browser user C would like to conduct a text based conversation 
within chat group #LB. 
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2. Using any IRC capable application, the web browser user C 
connects to the mobile chat proxy server 100, e.g., using the TCP/IP 
port 6700 (or other specified port). 

3. Once connected to the conventional IRC Server 190, the user joins 
the #LB chat group. 

4. The mobile chat proxy server 100 sends mobile user A a Reply 
Requested message asking them if they would like to engage in a 
chat with web browser user C at chat group #LB. If mobile user A 
accepts, then mobile user A is added to the LB chat group, thus 
allowing mobile user A and web browser user C to conduct a text 
based conversation. 

5. If mobile user A rejects, then web browser user C is notified, but the 
#LB chat group continues to exist with web browser user C as a 
participant. 

Scenario D: Web browser user initiating privat chat only with a mobile user. 

1 . Web browser user C wants to initiate a private chat only with mobile 
user A. 

2. Web browser user C submits A's MIN, and their desire to conduct a 
private chat with mobile user A, to the mobile chat proxy server 100. 

3. The mobile chat proxy server 100 creates a new chat group with 
web browser user C's name (or a unique derivative), and enters web 
browser user C into the newly created chat group. 

4. The mobile chat proxy server 100 sends mobile user A a Reply 
Requested message asking for confirmation to participate in a 
private chat with web browser user C. 

5. Mobile user A's response is shown to web browser user C. 

6. If mobile user A accepts, mobile user A is added to the chat group 
and any outgoing messages to 'CHAT' from mobile user A will be 
sent to web browser user C. 

7. If mobile user A is already in another chat group, then mobile user A 
must specify the destination of the message 
[[#]group__name[*]message. Alternatively, the mobile chat proxy 
server 100 can prompt the mobile user A for the identity of the 
desired chat group. 
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The mobile chat proxy server 100 allows mobile users to be in 
multiple chat groups simultaneously. However, if so, the mobile user must identify 
the name of the chat group a particular message is destined for. If the mobile 
user does not identify the name of the chat group, the mobile chat proxy server 
5 100 can send a message back to the mobile user requesting that they identify the 
name of the chat group for which the message is destined. The chat server can 
also be configured to limit users to joining only a single chat group at a time. 

Upon joining a chat group, the mobile chat proxy server 100 can 
send a message to the mobile user notifying him/her the name of the chat group 
io which they have joined, e.g., "You've joined group KB as 1234". The 
administrator can disable this behavior by the chat server. Unless an alias has 
been provided, mobile users may be identified by, e.g., the last 4 digits in their 
MIN (or unique derivative). 

The mobile user has the ability to create an alias. The alias may be 
1 5 in effect for the current chat session(s). A default alias may be used, e.g., if the 
mobile user has defined an alias through another web provisioning application. If 
so, the *ALIAS* command may be used to override the default alias for the 
duration of the chat session in that group. The administrator can disable the user 
alias feature. 

20 The mobile user's MIN number may be made invisible if the mobile 

user wishes. However, for mobile device-to-mobile device chat group 
conversation, the MIN should be present to provide the required call back 
information. 

Preferably, the mobile chat proxy server 100 can maintain statistics, 
2 ,s e.g., regarding the number of chat messages sent/received by each MIN, just as 
the SMSC 104 typically does. 

The mobile chat proxy server 100 is able to connect to multiple IRC 
Servers by simple changes in a configuration file. All operational parameters for 
the Chat Server are controlled through a configuration file. 
30 Exemplary classes which can be implemented in accordance with the 

principles of the present invention are shown in the following table. Of course, 
these classes are for exemplary purposes only. Additional and/or alternative 
classes may be implemented within the scope of the present invention. 

35 
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MESSAGE HANDLER CLASSES 

Message Class 
IRC Session Class 
Mobile Command Decoder 
Active Session Container 
Chat Server 
Mobile Sender 
Mobile Receiver 
MOChat Defined Exception 

Preferably, the mobile chat proxy server 100 is implemented to 
function while sharing a link ID, either with the wireless Internet gateway 106 or on 
its own. Moreover, the mobile chat proxy server 100 is preferably able to identify 
s incoming chat requests, and to differentiate from other incoming messages (e.g.. 
Delivery Receipts and MOE-mail requests). 

Based on a particular application, mobile users may be configured or 
otherwise controlled to not receive a copy of chat group messages that they've 
sent. 

io In the disclosed mobile chat proxy server 100, chat group messages 

to mobile devices may be limited to a predetermined number of characters, e.g., 
as defined by the administrator. Preferably, otherwise conventional gateway 
services, e.g., message truncation and linking, can be utilized. 

Fig. 3 shows how the invention is able to support various types of 

1 5 clients for Chat services. The software allows other applications, such as web 
servers and WAP Servers, to enroll participants in Chat groups. 

Fig. 4 shows an overview of the communications between the user 
of the mobile device 102, the short messaging system controller 104, the mobile 
chat proxy server 100, the database 108, the conventional IRC server 190, and 

2« IRC clients 502 participating in a chat group, in accordance with the principles of 
the present invention. 

In particular, as shown in Fig. 4, Mobile originated Chat allows a 
mobile user 102 using a cell phone to start a chat group. The mobile user 102 
generates a chat message 502, which is transmitted to the SMSC 104. The 

25 SMSC forwards the mobile originated message 504 to the mobile chat proxy 
server 100. The mobile chat proxy server 100 conducts user validation with 
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message 506, user options with message 508, and allows validated users to enter 
the chat group of the conventional IRC server 190 with message 510. The mobile 
user's chat group messages are copied to all chat group participants (IRC clients) 
502. Acknowledgements may be provided back from the IRC clients 502 to the 
conventional IRC server 190, to the mobile chat proxy server 100, to the SMSC 
104, and to the mobile user 102. 

On startup, the disclosed exemplary embodiment of a mobile chat 
proxy server 100 creates instances of the following primary objects for a 
ChatServer. These objects delegate to subclass and other objects for help. 



OBJECT 


DESCRIPTION 


MessageHandler 


Queue Based I hread that will process and dispatch 
all messages entering system. 


ConfirmationSession 
Container 


Whenever the MessageHandeler encounters an in- 
complete or ambiguous handheld message it will be 
the task of this object to clarify the message with the 
user. Once the message has been clarified it will 
then be sent back to the MessageHandeler. 


Logger 


Process tor logging errors/notices to a central 
location. Each top-level object created by the 
ChatServer will receive a reference to this object. 
This will be an instantiation of the Logger class 
defined in the WebGateway. 


MessageSender 


Abstract class which details the necessary methods 
anyone wishing to implement a new chat service 
must implement to integrate with MOChat 
seamlessly. 


MobileReceiver 


The object is responsible for receiving and 
disseminating all messages received from the 
SMSC. MobileReceiver implements the 
SMPPListener interface and communicates to the 
gateway using RMI. Upon creation MobileReceiver 
will create the MobileSender class. 


MobileSender 


Implements the MessageSender interface and is 
responsible for transmitting all messages to the 
SMSC. 


Config 


This object encapsulates all access to MOChat 
Configuration information. 


MobileCommandDecoder 


I his class will parse and return requested parts of 
Mobile Command. All new mobile commands added 
to MOChat must be implemented here. 


WebProvisionlnfo 


Returns requested information from the Web 
Provisioning database about a user when given a 
MIN. 
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Message 


primarily a data class that encapsulates all 
information about MOChat messages in system. 
Class also has the ability to read/save properties to 
an XML document. 


ReplyRequestMessage 


ouuudbb ot iviessage. usea wnen senomg reply 
requested messages to mobile user for 
Confirmation. 


IRCSession 


1 he IRCSession is a mini IRC Client. It encapsulates 
all conversations between the user and the IRC 
Server. 



The Config class will load the configurable parameters from a 
properties file, e.g., a "MOCHAT.properties" file. Preferably, the mobile chat proxy 
server 100 will be configurable through user options. In the disclosed 
embodiment, configuration information may be retrieved using the Config object 
class. 



Exemplary Format of Mobile Commands 

Transactions from cell phones may be initiated by sending a mobile 
originated (MO) message to address 3428 (CHAT) with the following format 
options: 



Join a group 


#<Group ID> 


To join all pre-defined favorite Chat Groups. 
A Web interface allows users to define their 
favorite groups 


J* 


Send a message: 
If only in one group 
If in multiple groups 


<message> 

#<Group ID> <message> 


Assign an alias 


A*<new alias> 


Summon another mobile user to join 


S*<MIN> 


Obtain information about groups: 
Which groups user has joined 
Who is in a group 


I* 

l*<Group ID? 


Prevent announcements from being made 
when joining/exiting groups 


H* 


Exit Chat 

To exit from all groups 

To exit a particular Chat Group 


B* 

B*<Group ID> 


Ghost chat messages to a MT device. To 
support MT devices, ghost requests can be 
sent from a web page or WAP/UP browser. 


G*<MIN> 
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Top Level Processing Logic for Mobile Chat Proxy Server 

Fig. 5 shows an exemplary top level sequence of 
events in an initial mobile originated connection using a mobile chat proxy server, 
in accordance with the principles of the present invention. 

Of particular note in Fig. 5, the IRemoteSMPPProxy process 
forwards the message to the MobileReceiver's receiveMessage method. This 
method will ensure that that the message is a mobile originated message. If it's a 
valid mobile originated message (i.e.. not a delivery/read receipt, etc.), then the 
chat message is added to the MessageHandler's queue. 

At that point, it is the job of the MessageHandler in conjunction with 
the ActiveSessionContainer to instantiated an instance of the IRCSession class to 
provide the services required by that mobile user. 

Fig. 6 shows an exemplary top level sequence of events in a mobile 
originated conversation using a mobile chat proxy server, in accordance with the 
principles of the present invention. 

In particular, as shown in Fig. 6, the IRemoteSMPPProxy process 
forwards the message to the MobileReceiver's receiveMessage method. This 
method ensures that that the message is a mobile originated message, if it's a 
valid mobile originated mMessage (i.e., not a delivery/read receipt, etc.), then the 
message is added to the MessageHandler's queue. The MessageHandler class 
in conjunction with the ActiveSessionContainer delivers the message to the users 
personal IRCSession for handling a sequence of events for an improperly 
formatted mobile originated message. 

Fig. 7 shows an exemplary top level sequence of events for an 
improperly formatted mobile originated message using a mobile chat proxy server, 
in accordance with the principles of the present invention. 

In particular, as shown in Fig. 7, an exemplary sequence of events 
for handling an improperly formatted message may be very similar to those of a 
mobile originated conversation as shown in Fig. 6. However, one difference in 
processing occurs when the MessageHandler processes the message. If the 
MessageHandeler is unable to accurately deliver the message, it transfers 
processing of the message to a ConfirmationSession. It is the responsibility of the 
ConfirmationSession to query the user for help in the appropriate processing of 
the message. The message will be discarded if the ConfirmationSession is 
unable to correct the message in a system defined time period. 
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Fig. 8 shows an exemplary processing of a message queue of a 
mobile chat proxy server, in accordance with the principles of the present 
invention. 

In particular, as shown in Fig. 8, the MessageHandler is responsible 
5 for dispatching messages to the individual IRCSession or chat source. 

In theMessageHandler, once a message has been validated, it is 
added to the internal message queue 310. The processQueue method of the 
MessageHandler checks the thread periodically (e.g., every x milliseconds) or 
when notified of a new item. The method processQueue dispatches the message 
io to the appropriate recipient. 

In the disclosed embodiment, the message queue 310 is a first-in, 
first-out (FIFO) type queue. Preferably, in the message queue 310, if the 
message is ambiguous, it is preferably dispatched to the ConfirmationSession 
Container for further processing. If the message is a SUMMON with the recipient 
1 5 ID indicating a mobile number, then a summon SMS message will be sent to the 
recipient. If the message proceeds through the ambiguity test and the SUMMON 
test, then it will be sent to the sender's IRCSession for further handling. 

In the disclosed embodiment, the MobileSummon executes within 
the same thread as the processQueue, but this need not necessarily be the case. 
20 Fig. 9 shows an exemplary sequence of events in an Applet-based 

conversation, in accordance with the principles of the present invention. 

In particular, as shown in Fig. 9, IRC clients (i.e., chat group 
participants) may connect to the conventional IRC server 190 using a 
conventional IRC chat group infrastructure or the Internet. Mobile users 102 may 
25 connect to the conventional IRC server 190 using a network or Internet connection 
including a mobile chat proxy server 100 in accordance with the principles of the 
present invention. 

The invention also supports mobile handsets that are natively 
running an IRC client. IN this case, the handset does not communicate through 
30 the SMSC but directly interacts with the chat server. Fig. 10 illustrates the 
components of an IRC chat group solution allowing IRC-enabled mobile handsets 
102 to participate in IRC chat groups using an Interworking Function (IWF) 
connection (in place of the SMPP connection shown in Fig. 1), in accordance with 
the principles of the present invention. 
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The IRC chat group solution using an IWF connection as shown in 
Fig. 10 includes specialized IRC servers, a Local Director 416, and customer- 
provided IRC chat clients. The IRC Servers support the IRC protocol as defined 
by RFC 1459 and as enhanced for Unicode support through the 1998 Microsoft 
5 draft IRCX proposal. Any IRC client is able to attach to the chat solution. Mobile 
clients do not attach directly to an IRC server. Rather, clients attach to a single 
virtual server as represented by the Local Director. The Local Director load- 
balances the traffic across multiple IRC proxy servers. Proxy servers perform 
special actions that are applicable for mobile users, such as sending notices via 

l0 SMS to users who are not connected to the chat server. If any proxy server 
becomes unavailable, then the Local Director automatically removes it from the 
pool of available servers. The Local Director will also automatically re-add servers 
that later become accessible. Interoperation between multiple servers is defined 
by the IRC specification. 

15 An IRC software module in the mobile user handset 102 allows 

mobile users to participate in chat sessions. This IRC software module is 
configured to automatically connect via IWF to a specified number. Customer 
provided MSP hardware' such as the Ascend TNT can convert traffic from the 
destination modem to a direct TCP/IP connection to the Local Director. Once a 

20 connection is established, the phone appears as any standard IRC client. 

Fig. 1 1 shows an initial connection to the IRC server shown in Fig. 
1 0, in accordance with the principles of the present invention. 

In particular, when the mobile user 102 initially connects, the IRC 
Proxy will validate whether that user has access to the specified service. Thus, 

25 user access to packet and e-chat services may be validated against the customer 
database 108 upon initial connection of that mobile user 102. 

Fig. 12 is a detailed process flow showing the validation of the 
mobile user 102 in the mobile chat system shown in Fig. 1 1 . 

in particular, as shown in Fig. 12, the mobile chat proxy server 100 

30 queries the provisioning database 108 for the access rights of the currently 
connected mobile user 102. If that mobile user 102 has access to the specified 
resources, then a connection to the conventional IRC server 190 will be initiated. 
Otherwise, the mobile user 102 may be informed of the reason for their denial via 
the mobile chat proxy server 100. Password validation can also be provided at 

35 this point. 
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After validating the mobile user 102, the mobile chat proxy server 
100 will forward all IRC traffic from the mobile user 102 to the conventional IRC 
server 190, after examination of all IRC commands for the mobile specific 
implementation. 

5 Fig. 13 shows an update of the provisioning database in the system 

of Fig. 10, in accordance with the principles of the present invention. 

In particular, short messaging system (SMS) administrators may be 
presented with an appropriate web page or web page link to connect them to the 
provisioning database of the Internet gateway 1101 (Fig. 10). From such a web 

lo page, the administrator may update relevant user information regarding chat 
group use. 

For instance, administrators may assign chat privileges to 
subscribers by accessing a custom link in the SMS web interface. This link may 
activate a preformatted form for assigning chat access to a particular MINI. 
i S SMS special enhancements may be implemented to the IRC to 

enhance the mobile-user's experience. 

For instance, Fig. 14 shows an exemplary process of an IRC 
"Notice" command, in accordance with the principles of the present invention. 

In particular, the IRC "Notice" command may be used to initiate SMS 
20 messages to mobile handset users. This IRC "Notice" command may be used, 
e.g., to broadcast a message across multiple groups in an attempt to reach the 
destination party. 

In one implementation, the mobile chat proxy server 100 will 
determine if the destination address for the Notice command is a MIN. If so, the 
25 Notice may be sent via the SMS to the mobile handset by way of the wireless 
Internet gateway 106. The wireless Internet gateway 106 can ensure that the 
message is successfully delivered to the mobile handset. If the Notice destination 
is not a MIN, then it is handled normally. 

IRC allows a user to issue commands. In the disclosed 
3o embodiment, example Notice commands to transmit a message to an identified 
user may be formatted as: 

NOTICE <user> <message>; and 

PRIVMSG <user> <message> 

The mobile chat proxy server 100 may enable these commands by 
35 using the SMS to notify the mobile recipient of messages directed to them. 
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Fig. 15 shows an exemplary IRC "Notify" command having special 
properties for an SMS, in accordance with the principles of the present invention. 

In particular, as shown in Fig. 15, a NOTIFY <user> command 
allows a mobile user to request notification from the SMS when a specified user 
5 connects. When the user connects, an SMS message is sent to the requesting 
user identifying the connected user and channel. This 'buddy list' notification 
allows any of the devices connected to the chat server to be notified of other users 
when they are available. 

With the Notify command, a mobile user can request to be notified 
io when another user accesses the conventional IRC server 190. Mobile users can 
utilize this feature by having SMS messages delivered to them when another user 
logs onto the conventional IRC server 190. In this way, mobile users can be 
notified when their friends are ready to chat. 

Preferably, notification requests remain active for only a specified 
1 5 period of time on the server. 

Fig. 16 shows a special "Ghost" command to enable a user to 
monitor an IRC chat group (or channel) via the short message service (SMS) 
without maintaining a connection to the conventional IRC server 190, in 
accordance with the principles of the present invention. 
20 In particular, the Ghost command may be considered to be 

equivalent to the IRC "mode +r command, as it is an IRC proxy implementation of 
the IRC "mode +i n command. Specifically, the user enters the "GHOST" 
command and disconnects from the conventional IRC server 190. Once 
disconnected, the mobile chat proxy server 100 will forward all messages received 
25 in the chat group (or channel) to the user via SMS messages through the wireless 
Internet gateway 106. This forwarding may be performed as long as desired, e.g., 
for a pre-configured, authorized, requested, or other period of time. The period of 
time may be system dependent. 

Fig. 17 shows the implementation of a special IRC "Invite" command 
30 to provide the mobile user with the opportunity to use SMS to extend chat 
invitations to other mobile users, in accordance with the principles of the present 
invention. 

In particular, as shown in Fig. 17, IRC protocols allow a user to issue 
the commands NOTICE <user> <message> and PRIVMSG <user> <message> to 
35 transmit a chat message to an identified user. In accordance with the principles of 
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the present invention, the mobile chat proxy server 100 may enhance these 
commands with an INVITE command. Using the INVITE command, the mobile 
chat proxy server 100 uses the short message service (SMS) to notify mobile 
users of messages directed to them. 

With the "Invite" command, the mobile user can request that the 
mobile chat proxy server 100 notify the specified user of a request to chat via 
SMS messaging. If the destination user is currently connected to IRC, they may 
be notified using the IRC protocol. 

Preferably, a mobile chat proxy server 100 in accordance with the 
principles of the present invention supports the core messaging features of 
conventional IRC protocol as defined in RFC 1459 and as enhanced for Unicode 
support in the 1998 Draft IRCX specification by Microsoft. In accordance with the 
principles of the present invention, mobile devices (e.g., mobile handsets) desiring 
to lurk in a chat group, or participate in a chat group, include a native IRC client 
application which supports the IRC specification as defined in RFC 1459 and 
supporting Unicode as defined in, e.g., Microsoft Corporation's draft specification. 

Preferably, the native IRC client application in the mobile device 
maintains a constant connection to the conventional IRC server 190 via the mobile 
chat proxy server 100 using the IWF for the duration of the chat session, during 
which time native IRC commands may be exchanged between the mobile user 
client and the conventional IRC server 190 as interpreted by the intervening 
mobile chat proxy server 100. 

Preferably, a TCP/IP socket connection will be established between 
the terminating IWF modem and the mobile chat proxy server 100. The 
conventional IRC server 190 preferably has TCP/IP access to the wireless 
Internet gateway 106 for delivering short message system messages. The mobile 
handsets and the IRC client software in the conventional IRC server 190 will 
properly establish an IWF connection when an SMS message with appropriate 
callback is received and the user presses 'talk*. A full-time Internet connection 
may be made available if Internet-based IRC clients will be accessing the mobile 
chat proxy server 1 00 . 

The invention has applicability for use by, e.g., wireless carriers, and 
as a portal site for mobile-terminated ghosting of chat groups. 

While the invention has been described with reference to the 
exemplary embodiments thereof, those skilled in the art will be able to make 
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departing from the true spirit and scope of the invention. 
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CLAIMS 

What is claimed is: 

1. A method of providing access to a channel of an Internet Relay 
Chat group to a mobile device, comprising: 

5 placing a mobile chat proxy server in a communication path between 

a standard Internet Relay Chat server and a wireless gateway server supporting 
said mobile device; 

wherein said mobile chat proxy server forwards chat commands 
from said mobile device to said standard Internet Relay Chat server. 

10 

2. The method of providing access to a channel of an Internet Relay 
Chat group to a mobile device according to claim 1 f wherein: 

said access includes participation in said channel by said mobile 

device. 

15 

3. The method of providing access to a channel of an Internet Relay 
Chat group to a mobile device according to claim 1, wherein: 

said mobile device comprises a mobile telephone. 

20 4 - The method of providing access to a channel of an Internet Relay 

Chat group to a mobile device according to claim 3 t wherein: 

said mobile telephone is a mobile originated telephone with respect 
to said accessed channel of said Internet Relay Chat group. 

25 5. The method of providing access to a channel of an Internet Relay 

Chat group to a mobile device according to claim 1 , wherein: 

said mobile chat proxy server interprets Internet Relay Chat 
commands from said mobile device. 

30 6. The method of providing access to a channel of an Internet Relay 

Chat group to a mobile device according to claim 1 , wherein: 

said mobile chat proxy server passes communications with said 
mobile device through an SMPP interface in a direction toward said mobile device. 
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7. The method of providing access to a channel of an Internet Relay 
Chat group to a mobile device according to claim 1 , wherein: 

said mobile chat proxy server passes communications with said 
mobile device through an Interworking Function (IWF) interface in a direction 
5 toward said mobile device. 

8. The method of providing access to a channel of an Internet Relay 
Chat group to a mobile device according to claim 1, further comprising: 

including a short message system controller between said mobile 
io chat proxy server and said mobile device. 

9. The method of providing access to a channel of an Internet Relay 
Chat group to a mobile device according to claim 1, further comprising: 

including a wireless Internet gateway between said mobile chat 
1 5 proxy server and said mobile device. 

10. The method of providing access to a channel of an Internet 
Relay Chat group to a mobile device according to claim 8, further comprising: 

including a wireless Internet gateway between said mobile chat 
20 proxy server and said short message system controller. 

1 1 . The method of providing access to a channel of an Internet 
Relay Chat group to a mobile device according to claim 1 , further comprising: 

summoning at least one other mobile device to join said Internet 
25 Relay Chat group. 

12. The method of providing access to a channel of an Internet 
Relay Chat group to a mobile device according to claim 1 , further comprising: 

ghosting said channel of said Internet Relay Chat group. 

30 
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1 3. A method of handling chat group commands between a mobile 
device and a chat group server, said method comprising: 

examining non-standard chat group commands transmitted by a 
mobile device; and 

5 forwarding standard chat group commands based on said non- 

standard chat group commands to said chat group server. 

14. The method of handling chat group commands between a 
mobile device and a chat group server according to claim 13, wherein: 

io said chat group server is an IRC server. 

15. The method of handling chat group commands between a 
mobile device and a chat group server according to claim 14, wherein: 

said standard chat commands are standard IRC commands. 

15 

16. The method of handling chat group commands between a 
mobile device and a chat group server according to claim 14, wherein: 

said non-standard chat commands are non-standard IRC 

commands. 

20 

17. The method of handling chat group commands between a 
mobile device and a chat group server according to claim 13, further comprising: 

intercepting said chat group commands from said mobile device 
before reception by said chat group server. 

25 

18. The method of handling chat group commands between a 
mobile device and a chat group server according to claim 13, further comprising: 

validating a user of said mobile device before forwarding said chat 
commands to said chat group server. 

30 

19. The method of handling chat group commands between a 
mobile device and a chat group server according to claim 18, wherein: 

said chat commands are IRC commands. 
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20. Apparatus for providing access to a channel of an Internet Relay 
Chat group to a mobile device, comprising: 

a mobile chat proxy server in a communication path between a 
standard Internet Relay Chat server and a wireless gateway server supporting 
s said mobile device; 

wherein said mobile chat proxy server forwards chat commands 
from said mobile device to said standard Internet Relay Chat server. 

21 The apparatus for providing access to a channel of an Internet 
i 0 Relay Chat group to a mobile device according to claim 20. wherein: 

said access includes participation in said channel by said mobile 

device. 

22. The apparatus for providing access to a channel of an Internet 
15 Relay Chat group to a mobile device according to claim 20, wherein: 

said mobile device comprises a mobile telephone. 

23. The apparatus for providing access to a channel of an Internet 
Relay Chat group to a mobile device according to claim 22, wherein: 

20 said mobile telephone is a mobile originated telephone with respect 

to said accessed channel of said Internet Relay Chat group. 

24. The apparatus for providing access to a channel of an Internet 
Relay Chat group to a mobile device according to claim 20, wherein: 

25 said mobile chat proxy server interprets Internet Relay Chat 

commands from said mobile device. 

25. The apparatus for providing access to a channel of an Internet 
Relay Chat group to a mobile device according to claim 20, wherein: 

30 said mobile chat proxy server passes communications with said 

mobile device through an SMPP interface in a direction toward said mobile device. 
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26. The apparatus for providing access to a channel of an Internet 
Relay Chat group to a mobile device according to claim 20, wherein: 

said mobile chat proxy server passes communications with said 
mobile device through an Interworking Function (IWF) interface in a direction 
s toward said mobile device. 

27. The apparatus for providing access to a channel of an Internet 
Relay Chat group to a mobile device according to claim 20, further comprising: 

a short message system controller between said mobile chat proxy 
io server and said mobile device. 

28. The apparatus for providing access to a channel of an Internet 
Relay Chat group to a mobile device according to claim 20, further comprising: 

a wireless Internet gateway between said mobile chat proxy server 
i s and said mobile device. 

29. The apparatus for providing access to a channel of an Internet 
Relay Chat group to a mobile device according to claim 27, further comprising: 

a wireless Internet gateway between said mobile chat proxy server 
20 and said short message system controller. 

30. The apparatus for providing access to a channel of an Internet 
Relay Chat group to a mobile device according to claim 20, further comprising: 

means for summoning at least one other mobile device to join said 
75 Internet Relay Chat group. 

31. The apparatus for providing access to a channel of an Internet 
Relay Chat group to a mobile device according to claim 20, further comprising: 

means for ghosting said channel of said Internet Relay Chat group. 

30 
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32. Apparatus for handling chat group commands between a mobile 
device and a chat group server, comprising: 

means for examining non-standard chat group commands 
transmitted by a mobile device; and 
5 means for forwarding standard chat group commands based on said 

non-standard chat group commands to said chat group server. 

33. The apparatus for handling chat group commands between a 
mobile device and a chat group server according to claim 32, wherein said chat 

io group server comprises: 

an IRC server. 

34. The apparatus for handling chat group commands between a 
mobile device and a chat group server according to claim 33, wherein: 

15 said standard chat commands are standard IRC commands. 

35. The apparatus for handling chat group commands between a 
mobile device and a chat group server according to claim 33, wherein: 

said non-standard chat commands are non-standard IRC 

20 commands. 

36. The apparatus for handling chat group commands between a 
mobile device and a chat group server according to claim 32, further comprising: 

means for intercepting said chat group commands from said mobile 
25 device before reception by said chat group server. 

37. The apparatus for handling chat group commands between a 
mobile device and a chat group server according to claim 32. further comprising: 

means for validating a user of said mobile device before forwarding 
30 said chat commands to said chat group server. 

38. The apparatus for handling chat group commands between a 
mobile device and a chat group server according to claim 37, wherein: 

said chat commands are IRC commands. 

35 



29 



WO 01/69406 



1/18 



PCT/US01/08212 



Standard IRC Server 



Jdbc 



ORACLE DATABASE 
(optional) 



108 



-190 



IRC protocol 

(connection for each client) 



Mobile Chat 
Proxy Server 



a RMI 



-100 



Jdbc 



p \ Wireless Internet Gateway 06 



SMPP 



| SMSC | ^-104 



Mobile Handset 



-102 



FIG. 1 



SUBSTITUTE SHEET (RULE 26) 



WO 01/69406 



2/18 



PCT/US01/08212 



-192g 



y IRC Clients 
/ L| IRC Clients | 





IRC Clients 



I 



I IRCCIients~| 
Lj IRC Clients | 



202 



IRC Clients 



IRC Server 



J 90b 

\TCP/IP 




jlntern et 
IRC (port 6667) 



IRC (port 6667) 

K--490a 



IRC Server 



u IRC (port 6667) 

-100 



Mobile Chat 
Proxy Server 



RMl (port 1099) 
(send/receive SMPP objects) 



106 



SMPP (ports 7001/7002) 




-102 



FIG. 2 



SUBSTITUTE SHEET (RULE 26) 



WO 01/69406 



3/18 



PCT/US01/08212 




FIG. 3 



SUBSTITUTE SHEET (RULE 26) 



WO 01/69406 



PCT/US01/08212 




SUBSTITUTE SHEET (RULE 26) 



WO 01/69406 



PCT/USOI/08212 



O 
CD 



5/18 











IRC 


| Serv 




LO 

d 



SUBSTITUTE SHEET (RULE 26) 



WO 01/69406 



PCT/US01/08212 



6/18 




SUBSTITUTE SHEET (RULE 26) 



WO 01/69406 



PCT/US01/082I2 



7/18 




SUBSTITUTE SHEET (RULE 26) 



WO 01/69406 



PCT7US01/08212 



8/18 




00 

CD 



=> 
LU 
3 

o 

LU 

8 

CO 
CO 
LU 



o 
o 

CO 
CO 
ID 
O 
O 
CC 



SUBSTITUTE SHEET (RULE 26) 



WO 01/69406 



PCT/US01/08212 



9/18 




0) 

E 

~ 8 
«?§ 
c * " 

Z * g 

C »- <D 

<D O > 
W « <j> 
O 3 tO 
SoO« 

• 2£ g 

8 g if 
"sol 

— U S CL 



< 

CO 
0C 
LU 
> 

o 
o 

o 

LU 

CO 
< 

m 
i- 

LU 
—I 
CL 
CL 
< 



CO 



UU 
> 
LU 
LL 

O 

LU 

O 

z 

LU 

o 

LU 
CO 



05 
O 



O) 

c 
"to 

CO 



_ 8 



£8 



a 

<D 

d> 

a 



8 



T3 

C 

at 



to .O = 

^ (D ™ CO <D 

a> 5 a> <o 

5 1 1 8 8 2 



SUBSTITUTE SHEET (RULE 26) 



WO 01/69406 



PCT/US01/08212 



10/18 



102 





1102 



erlWF 



Mobile 
User 
with IRC 
Client 



1101 



Web/ Desktop 
IRC Client 



RMI 



/Optional 



IR 



IRC Server 
(1.JM) 



Public IRC 
Server 



IRC Server 
(1..N) 



/ Optional 



IRC Protocol 



IRC Proxy 
(1..N) 



IRC Proxy 



ISP Server 


2 

4 ► 


Local 




Director 









IRC over 
TCP/IP 



FIG. 10 



SUBSTITUTE SHEET (RULE 26) 



WO 01/69406 



PCT/US01/08212 



11/18 




SUBSTITUTE SHEET (RULE 26) 



WO 01/69406 



PCT/US01/082I2 



12/18 




SUBSTITUTE SHEET (RULE 26) 



WO 01/69406 



PCT/US01/08212 



13/18 




-CZZ}- 



CO 

d 

LL 



















c 




"c 




o 












g 




Q_ 




CD 




"5 




CD 




CP 




c 















o 

CD 
CO 



- -c 

c 
c 

,2 
S2 
*> 
o 

a. 

O 

5 



UJ 

£L 
Z> 
LU 
CO 
< 
CO 

I 



o 

CO 

> 
o 
cr 
a. 



CD 




















.£= 




*c 




.2 

CO 








1 




Q_ 




CD 




CO 




03 

■a 




TS 




Q 




CO 








CO 





o 

CD 
CO 

< 



- -L 



SUBSTITUTE SHEET (RULE 26) 



WO 01/69406 



PCT/US01/08212 



14/18 




SUBSTITUTE SHEET (RULE 26) 



WO 01/69406 



15/18 



PCT/US01/082I2 




SUBSTITUTE SHEET (RULE 26) 



WO 01/69406 



PCT/US01/08212 



16/18 




SUBSTITUTE SHEET (RULE 26) 



WO 01/69406 



PCT/US01/08212 



17/18 




CD 

Li. 



Q 
Z 
< 



o 
o 

LU 



CM 
O 









© 




O 




O 




cr 




_© 








o 




2 





? 

a 
E 
E 

3 

> 



SUBSTITUTE SHEET (RULE 26) 



WO 01/69406 



PCT/US01/08212 



18/18 



192a 192b 




FIG. 18 Prior Art 



SUBSTITUTE SHEET (RULE 26) 



INTERNATIONAL SEARCH REPORT 



International application No. 
PCT/US01/08212 



A. CLASSIFICATION OF SUBJECT MATTER 

IPC{7) : G06F 15/16 

US CL : 709/204, 227, 228, 229 
According to International Patent Classification (IPC) or to both national classification and IPC 



B. FIELDS SEARCHED 



Minimum documentation searched (classification system followed by classification symbols) 
U.S. ; 709/204. 227, 228, Z29 



Documentation searched other than minimum documentation to the extent that such documents are included in the fields searched 



Electronic data base consulted during the international search (name of data base and, where practicable, search terms used) 
EAST 



C. DOCUMENTS CONSIDERED TO BE RELEVANT 



Category* 



Citation of document, with indication, where appropriate, of the relevant passages 



Relevant to claim No. 



x 

Y 

Y,P 
A,P 
A,P 



US 5,960,074 A (CLARK) 28 September 1999, col. 3, lines 1-10, 
col. 5, lines 44-65. 



US 6,178,331 Bl A (HOLMES et al.) 23 January 2001, col. 2, lines 
45-65, col. 11, lines 16-65. 

US 6,185,602 Bl A (BAYRAKERI) 06 February 2001, col. 3-col. 
11. 

US 6,078,583 A (TAKAHARA et al.) 20 June 2000, col. 4-col. 10. 



1-6, 7, 9-24, 26, 
28, 30-38 

6, 8, 25, 27, 29 

6, 8, 25, 27, 29 

1-38 

1-38 



| x| Further documents are listed in the continuation of Box C. | | See patent family annex. 



Special categories of cited documents: 

document defining the general slate of the art which is not considered 
to be of particular relevance 



"E" 

"L" 



-O" 
- p - 



earlier document published on or after the international filing date 

document which inay throw doubts on priority cUun(s) or which is 
cited to establish the publication date of another citation or other 
special reason (as specified) 

document referring to an oral disclosure, use, exhibition or other 
means 

document published prior to the international filing date but later than 
the priority date claimed 



later document published after the international filing date or priority 
date and not in conflict with the application but cited to understand toe 
principle or theory under lying the invention 

document of particular relevance: the claimed invention cannot be 
considered novel or cannot be considered to involve an inventive step 
what the document is taken alone 

document of particular relevance; the claimed invention cannot be 
considered to irvolve an inventive step when the document is 
combined with one or more other such documents, such combination 
being obvious to a person skilled in the art 

document member of the same patent family 



Date of the actual completion of the international search 



04 MAY 2001 



Date of mailing of the international search report 

07JUN20Q1 



Name and mailing address of the ISA/US 
Commissioner of Patents and Trademarks 
BoxPCT 

Washington, D.C. 20231 
Facsimile No. (703) 305-3230 



Authorized officer 
TOD KUPST> 
Telephone No. 703-305-2655 



Form PCT/ISA/210 (second sheet) (July 1998)* 



INTERNATIONAL SEARCH REPORT 



International application No. 
PCT/US01/08212 



C (Continuation). DOCUMENTS CONSIDERED TO BE RELEVANT 

Category* Citation of document, with indication, where appropriate, of the relevant passages Relevant to claim No. 

A US 5,966,663 A (GLEASON) 12 October 1999, col. 10-col. 30. 1-38 

A US 5,949,326 A (WICKS et al.) 07 September 1999, col. 3-coI. 5. 1-38 

A US 5,867,495 A (ELLIOT et al.) 02 February 1999, see all. 1-38 



Form PCT/IS A/210 (continuation of second sheet) (Jury 1998)* 



